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1.0 INTRODUCING! 



1.0 mi&flfiUCIMH 



Thus far* automated document generation here at CDO has 
been accomplished using low level commands which* for the most 
part* only work on immediate and limited portions of text. 
Few commands exercise significant control over large portions 
of text. As a result* document preparation is hampered by the 
relatively large amount of work needed to orepare a text file 
for submission to a text formatter suc*i as TEXTJA8 or TXTFQRH. 
In TXTF0RJ1* lines containing commands often outnumber lines of 
text. Thus* the input file to the formatter is hard to read 
and work on. 

TXTCODE is designed to allow high level formatting 
instructions* which correspond directly to common text 
structures* to be used to direct document generation. In this 
way* commands of great power and range are able to format a 
whole "text structure" using* in some cases* only an escape 
code and a word. 

TXTCODE is designed so that the text beircg input by the 
user will help to trigger in his mind the appropriate TXTCODE 
command* or format. The entered text also suggests to the 
user the format of the original. Since relatively few codes 
are present the input file is normally very readable. Thus 
on-line editing is simpler too - both visually and from an 
EDITing standpoint. TXTC00E f s input format* which is 
basically free-form* allows lines and text strings to be 
freely replaced* added and deleted. 
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2*0 MSfi£-0£-Q£EEMIQa 

£JUl£S££&£ 



The basic idea of TXTCOOE is to have a command which 
corresponds to the text structure which is being input* so 
that the formatter "knows** what it's trying to construct. 
Thus it Milt interpret the input in the context of what it is 
expecting and fit the input into the expected pattern* To 
keep things synchronized* each input "mode" (context) has souse 
simple conventions which trigger formatting actions at the 
correct time. These conventions consist o?s 

• blanks at the start of some lines 

• trigger characters embedded in the text for some modes 



Qstiniiiaas 



8LANK LINE; a line which has no text data on it on input 
Mill normally generate one blank line at that point in the 
text on output* 

COMMAND LINE: lines which start in position one with the 
master escape character (back slant \ by default* located to 
the right of the blue RETURN key on 713 terminals*, are 
assumed to be TXTCOOE command lines. Such lines are used to 
give various kinds of instructions to the formatter. In some 
cases* text is expected on the same line with the command. 

OATA LINE: any line which is not a BLA^K LINE or a COMMAND 
LINE is interpreted as a OATA LINE. This type of line i% 
processed by the currently active mode (ASIS* SLOCK* COMMENT* 
FL0WTA8* ITEM* or TABLE) and is formatted into the 
corresponding text structure. 



NOTE: Under certain circumstances* any or all of the above 
types of lines may be ignored by the formatter* This happens 
in two cases: 1) a \ST0R command has been issued and a \G0 has 
not been encountered* 2) a \TXTF command was given and a VENDT 
has not yet been found. The STOP/GO takes precedence over the 
TXTF/ENOT command. 
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££&££&&iO£2 



The 6 mode commands and the section number commands are the 
heart of TXTCODE and with the occasional use of some of the 
other commands most text forms should be easily handled. 

Before describing the commands and modes.*' an overview of 
TXTCODE 1 s approach will be given. 

At the highest level* \ST0P and \G1 have absolute control 
over the input file. All input text following a \ST0P* until 
a \G0 occurs will be utterly Ignored* Thus sections of the 
input file may be "turned-of f **• 

The next level down is TXTF/ENDT* Dnce \TXTF has been 
called* all input to TXTCODE (which reaches this level) is 
assumed to be for TXTFGRM processing* Hence* the information 
is simply passed along to TXTFORH until a \ENDT is encountered 
which returns control to the current mode* TXTFQRM would only 
be called though* if TXTCODE couldn f t format's certain section 
of input text* With the addition of direct TXTFORH commands* 
there should be very few cases where \TXTF and \ENDT are 
actually needed* It should be used mainly to encapsulate 
existing TXTFORH input text. 

Going down another level brings the Input to TXTCODE 
proper* The input line is first checked to see i f it starts 
with the escape code (usually \) and* If so* the mode is 
altered or some feature is set on/off etc* If the line does 
not start with the escape code* It is orocessed by the mode 
which is currently operational (i*e* interpreted according to 
the present context) with consideration given to any "feature** 
which is active at that time. (e.g. 4USTI f i cat ion ON in 
TABLE mode has no effect)* 

Normally a blank input line is used to generate a blank 
output I ine* 

Input line length is 80 characters of Information. 
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3.0 SUflflA&X.Q£-£QttlUJlflS 



A 1 i commands 
uppercase. 



lay be entered in either lowercase 



or 



Input File Control Commands 

\ST0P 
\G0 
\TXTF 
\ENDT 

Mode Commands 

\ASIS 

\BLOCK>Jnn>Inn»Hnn 
YCQMMENT 
\FLGWTABxtt#tt>...tt*ff 



eq. VBlOCKfJl 

\FL3WTAB Jl*20 



\ITEM» Jnn» Inn>Snn> Gnn> Hnn* Zxx*C = e* 0- VITEM>S? 



\NONESTIND 



\TABLExtt,tt#...tt 

Mode Nesting Commands 

\*£* *.+1mode command \+t..*+3 

\-t..*-3mode command V-C...-3 

\*mode command 

\NESTIN0 

\EXITNEST,C 

VCLEARNEST 

Designation Text Control 

\TITlEn*xxx. . . x 
\DATE*xxx. «.x 
\F 01 10* xxx ...x 
XTA8LC0N 
XAUTOSEC 

Text Body Commands 

• Section numbers 

\ n.n. *««n xxxxx».*x or 
\SETSECnn 



\TA8LF;10,20,30... 



\TITLE*xxxx* s . .x 



\NQAUT0SE 



\ n xxx 



or 



\ xxx 



• Feature Selection De-selection 
\B0LD \N0B0LD 
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\COOES 

VHEADA \HEAD8 

\JUST \NtUUST 

\KEEPn \NOKEEP 

\MARK 

\PARA \PARAnn 

\SEQ \NOSEQ 

\SINGLE \OOUBLE 

\UNOER \NOUNDER 

Text Format Control 



\HEADC 



XNOPARA 



\M4RGIN*nn 
\L5MGTH*nn 



\HARGINnn \HARGIN 

XlENGTHnn XLENGTH 

\SKIPnn 

\PAGE \PAGEnnn 

\CENT£R=xxx...x \CENTER >B>U*xxx . • . x 

\SiANKnn 

• Appendices 

VSETAPP»a-xxx...x 

• Box Generation Commands 

\80X \BOX> t-lnn* A, nnjBjt-ln^R, t-]n* 
\MQDB0X>O3nn# A>nn*B*t-3nn*R>l>:im 
\8QXLINE 
\NOBOX 

• Escape Character Definition 

\SETEx 
\SETUx 
\SETBx 
\SETHx 

Direct TXTFORM Commands 

Wcommand 



\MARGIN-nn 
UENGTH-nn 
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^•0 fl£S££l£IIQfi.fl£.ttanfi 



One mode of the 6 <ASIS* BLOCK, COHMENT* FLOtfTAB* ITEM, or 
TABLE! is always active even if VSTOP or \TXTF has been 
called* When the \GQ or \ENDT is giver** the mode resumes 
processing as if it had not been interrupted. 

The initial mode is BLOCK. Transition to another mode is 
accomplished by simply calling the desired mode with or 
without any mode parameters. Initially the left margin is set 
at 10* and the right margin to 62 positions to the right of 
the left margin (i.e. LENGTH62). 

Relevant features such as PARA or JUST are honored if they 
are applicable to the active mode. 

All of these modes process commands issued within the mode 
and* unless specified otherwise* each node processes any 
active trigger characters for under I i ni rig. boldfacing* and 
hard blanking. 



4.1 A£I£_£QB£ 
\ASIS 

Each data line encountered by the ASIS mode is copied as~is 
to output with no adjustment made to the line structure. The 
lines start at the margin and will be truncated If longer than 
62 characters (default length). See the LEMGTH command. A 
blank line produces a blank line on outout. 

PARA and JUST have no effect on as-is text. The 
underlining* boldfacing or hard-blank trigger characters are 
not recognized as trigger characters in ASIS mode. However 
the VBOLD command may be used to boldface one or more whole 
I i nes of as-l s text. 



Exampl e» 

SONE +- + 

ASIS 1 ASIS \ 

TEXT ♦- ♦ 
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4.1 ASIS HOOE 



Inputs 

Vasis 

SOME ♦— «■ 

ASIS 1 ASIS J 

TEXT + ♦ 

Vblock 



4.2 SLQ££-£1QI2£ 

\ BLOCK* Jnn#Inn*Hnn 

Block mode forms paragraphs from "text BLOCKs" passed to 
it. Note that a text block of one character is permissible* 

A "text block* 1 is a set of one or more lines of data which 
is started by a line of text with a blank in column one* and 
ended by either the next line with a blank in column one or by 
a command which places text in the output at that point* 

Each text block is started on a new line and is normally 
right justified between the left and right margins. A blank 
line produces a blank line* A series of lines which start 
with a blank in column one would appear as a list at the left 
margin. 

If the data for a text block starts in column two* the 
generated paragraph will begin at the left margin. But if x 
additional blanks are left after the text block start blank* 
the Mllfiis text block will be indented by x positions from the 
left margin. 

If the PARAgraph feature is on* the first line In a text 
block will be indented by three spaces' from- the margin. See 
the PARA command. 

J specifies the number of lines ir\r\) to JUMP at the 

beginning of each text block* This is in addition to 

any lines skipped by explicit TXTCODE commands. The 
default is JO. 

I INDENTS the first line of the text block r\n positions 
from the margin. The default is 13. 
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4.2 BLOCK NODE 

H HANGs (indents) the second and succeeding fines of the 
block text nt\ positions from the nargin. The default is 
HO. 



Examples 

This format* which is a BLOCK mode »aragraph» is generated 
by the input shown below under Input. 

Indentation like this is accomplished with additional 
blanks on the first line of the text block. The PARAgraph 
feature is on throughout. 



Inputs 

This format* which is a BLOCK mode paragraph* is 
generated by the input shown below under' Input. 

Indentation like this is accomplished with 
additional blanks on the first line of the text 
block. The PARAgraph feature is on throughout. 



4.3 £QttU£l!lL.i!QAE 

XCOMHENT 

Comment mode ignores all non-connand lines. Note that 
commands are still processed* including text on the command 
line. This is in contrast to \ST0P which ignores everything 
until a subsequent \G0 is received. Comment is not intended 
to be used to "turn-off" sections of the input file - use 
STOP/GO. 



4.4 ELQMIAfi-JSQflf 

\FLOWTABxtt#tt»...tt#ff eg. VFLOWTAB: I, 20 

This mode allows text which is to "How** between a left 
start position and the right margin to start on the same line 
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4.4 FLQWTAB MODE 



as text which has been tabbed into position. 

The first character x after the sommand* if non-blank* 
resets the tab character to the given character. The tab 
positions follow. CDefauits are |1*20.) The last position 
given specifies the start position for the flowing text. Note 
that text lay be tabbed left and right of the text which is to 
flow between the given start position and the right margin. 
When tabbing to the right* it is usually necessary to first 
adjust the right margin using the XLEMGT^-nn command. The 
original right margin may be restored by using the MENGTH 
command. 

Data is entered in the order of the tabbing sequence used 

in the command. Tabbing is relative to the left margin* so 

that a tab set to 1 will cause the associated text to start 

immediately to the right of the left margin. 

Each line starting with a blank forces a new line. An all 
blank line leaves* as usual* a blank line In the output. 

A text block which starts with a blank but which does not 
have the tab character specified next* is assumed to be 
flowing text and is placed at the last posi tion spec i f i ed in 
the command. Any x additional blanks after the first one* 
cause the text block as a whole to be Indented x positions 
from the beginning of the flowing text. 

NOTE? Once the flowing text is reached, the tab character 
may be used freely in the flowing text. 

See the SETHx command if a "hard blank'* (ie. 
non-compressible) character would be useful in positioning the 
tabbed information. 

The following shows how to set up soue FL0WTA8 type texts 

Ex am pi e J 
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4.4 FL0WTA8 HODE 

iUHBAliS £MAM£I£££ ££IIOM 

ADD YES Add the given files to the tape 

Ubrary &r\6 put the comment 
Information on the last file 
given. 

DAYFILE NO Leave dayfile for batch job on a 

permanent Hie when done. 

This starts at the flowing text 
position; the tab character may 
be used nornally here. 

This Is indented by four 
positions throughout the 

par agr aoh. 

Input: CYSETU specified at start of document) 

\keepl7 

\FL0WTA8U*15,30 
I^COHflAND" ;~PARAWETERS~ J~ACTIQN~ 

J ADD JYES ;Add the given files to the taoe library 
and put the comment information on the last file given. 

;DAYFILE;NO jleave dayfile for batch Job on a 
permanent file when done. 

This starts at the flowing text position; the tab character 
may be used normally here. 

This is indented by four positions throughout 
the paragraph. 
\ b I o ck 



4.5 HEtt-ttQfifi 

VITEMt 4nn#Inn*Snnp Gnn# HnntZxx»C*e>0 eg. MTEN- 

Item mode allows the user to generate a properly indented 
and aligned list of items where each iten Is normally preceded 
by some character string such ass -» *» • » l.!» ta)> A.* or 1) 
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4*0 DESCRIPTION OF MOOES 
4*5 ITEM HQOE 

etc* The above examples* plus any prefix character string* 

are handled juiaiaii.it JlJLx unless ITEH node is called with its 

own settings* ITEH mode will set up default values for ail 
parameters that are not supplied on the command.' 

Notice that the default value of one parameter can be 
automatically altered by specifying another parameter. E.g. 
giving G4 alters the default value of H* 

{Preceeding the input data for the following six paragraphs 
with the command **\ITEM W would format that text as it appears 
below) • 

J specifies the number of lines inn) to JUMP at the 
beginning of each new item* This is in addition to any 
lines skipped by explicit TXTCODE or TXTFORM commands* 
The default is JO* 

I indicates the prefix characters are to be INOENTed from 
the margin by an amount nn* The default value for I 
depends upon the resulting value for S» see the table 
below* 

S specifies the SIZE of the prefix string as nn* inn may 
be greater than 3)« The first actual item encountered 
will set the SIZE for the prefix string area* unless the 
S parameter is given on the ITE*1 command* Subsequent 
prefix strings will left adjust In the orefix string 
field if shorter than the first prefix string* while 
longer prefix strings will be right adjusted in the 
prefix string field* 8y specifically giving a large or 
small S value* the prefix string information can be 
forced to be left or right justified within its field* 

G gives the GAP after the prefix string; nn columns. The 
default value for G is determined! from the table below 
using the resulting value for S* 

H HANGS the text which overflows line one under the first 
non-blank character following the prefix string or as 
requested. The default value for H is equal to I+S+G* 

ZpCfO These are the parameters controlling automatic item 
label generation* A full description of these 
parameters is given in the section on Automatic Label 
Generation of Itemized Lists which follows shortly* 

The following diagram shows the meanings of the various 
terms used; 
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4.0 DESCRIPTION OF HODES 
4*5 ITEH HQDE 



4— — Hang Amount (e*g* 6 spaces) 

+ Indentation (e.g. 3 soacesl 

4. Prefix String <s*g. f 2 characters) 

I + — - Gap <e.g. 1 space) 

I j + Text 8ody 

V V V V 

_ „ „„. , X * _ X X X X a X X X * * * X X X 
♦-> XXX XX. 



Blank lines produce blank lines on output.* Each tine which 
starts with a blank forces a new line to be started. 

The prefix string ends at the second bl ank character in the 
line* Hence* if positions one and two are blank a null prefix 
string is assumed and text starting in column three would be 
aligned with the text body of the previous item. 

Any x additional blanks in columns 3*4*.. • cause the 
following text including overflow portions to be indented from 
the text body of the previous item by x positions throughout. 

Finally* text which starts in position one o<" the line jad 
which follows a blank line* will be treated as a no n- item and 
aligned at the left margin. 

The following table shows how ITEM will set up its I* S* G 
and H values for various sizes of prefix strings when the 
first item is encountered? 



1 
2 
3 
4 
5 + 



Inn 

3 
3 
2 
1 





San 

1 
2 
3 
4 
5+ 



2 

1 
1 
1 
2 



aaa (i+s+G) 

6 
6 

6 

7 + 



Ii£fl_£A£Affi£ifi£~Q££aul£S.X'a]llfi' 



Ex amp I e: 

The input shown below would produce the format shown above* 
where the J* I* S* G* H# E* C* and parameters are explained? 
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4,0 DESCRIPTION OF MODES 
4.5 ITEM MODE 

Inputs 

\ it sis 

J specifies the number of lines inn) to JUM*- at the beginning 
of each new item* This is in addition to any lines skipped 
by explicit TXTCODE or TXTFGRM commands. The default is JO. 

I indicates the prefix characters are to be IND^NTed from the 
margin by an amount nn» The default value f3r I depends upon 
the resulting value for S| see the table below. 

S specifies the SIZE of the prefix string as nn. (nn may be 
greater than 3). The first actual iten encountered will set 
the SIZE for the prefix string area* unless the S parameter 
is given on the ITEM command. Subsequent prefix strings will 
left adjust in the prefix string field if shorter than the 
first prefix string* while longer prefix strings will be 
right adjusted in the prefix string field. Sy specifically 
giving a large or small S value* the prefix string 
information can be forced to be left or right justified 
within its field. 

G gives the GAP after the prefix string; nn columns. The 
default value for G is determined from the table below using 
the resulting value for S. 

H HANGS the text which overflows line cine under the first 
non-blank character following the prefix string or as 
requested. The default value for H is eguaf to T+S+G. 

Z*C*0 These are the parameters controlling automatic item 

label generation. A full description of these parameters is 

given in the section on Automatic Label Generation of 

Itemized Lists which follows shortly. 
\block 



iiiIfliJti£-.Ljl2fil.SfiBfiLaiiii£i-an-Itfiiii£il-.Iis];s 

The following parameters exist on the item command to 
implement the automatic labelling of Items? 

• Z I x • • x 1 C a • • a 1 1 b • • b H c H d • • d J J » C = 9 • 

Each of the parameters are optional and have the following 

meaning: 

Z * L or I - auto label with letters: A* B* C... or' a* b> c»*. 
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4.5 ITEM NODE 



N or n - auto label with numbers? 1* 2» 3*** 
R or r - auto label with romanJ I* T£. III* IV?.. or 

i. II, Hi, ivi,, 

In the absence of the x**x portion of the conmand* the case 
of the W Z M determines the case of the generated labels* 
Otherwise* x«.x is used to specify both a non-default starting 
value and the case* 

x*.x a starting value for labelling* If it is present and is 
compatible with "Z^'s type* Otherwise it is treated as 
a • « a text* 

a**a suffix text to follow each generated label when no *** w 
option is used in the parameter. 

*•»*» used for more complex types of auto generated label text 
where b**b text is to be specified. 

b**b text which is to precede the auto generated string* It 
might be a m { n for an faJ# (b) tyoe sequence. 

c a point of substitution single character for the auto 
generated sequences* which is **.'* by default* It may 
be redefined using the "*C«8 W parameter* where "C H 
stands for "character" and "e" is the new editing 
substitution character to assume both in the command and 
in the following text data prefix strings* 

d**d suffix text to follow each auto generated string. It 
might be a W )* H such as for arc (A).» <B)»* type 
sequence* 

C*e e is a single character which is to define the point of 
substitution position for the auto generated strings* 
This is for both the command itself and the text data 
which follows the command* 

Override parameter. When this parameter is specified on 
the command* the point of substitution character is not 
sought for in the prefix string region of the text data* 
Any non-null character string for a Drefix region is 
completely removed and replaced with the auto generated 
sequence* It may or may not contain the actual 
substitution character. 
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4*0 DESCRIPTION OF MODES 
4,5 ITEH MODE 



EyQiiiiaaiaa 

The basic process that occurs is as follows* 

The label type* starting value* and case Is determined from 
the W Z W and any x**x* This material is the auto generated 
string and will be incremented for each substitution that 
occurs* If there is any a**a materials it is used to set up 
the area that supplies the suffix for each auto generated 
string* If there is an "** in tie command parameter* 
everything following the M = w (until the end of the parameter - 
n f n or m « reached) until the point of substitution is found* 
becomes a prefix to the auto generated string* 

When the substitution character Is Found* any text 
following this character until the er^d of the parameter is 
used to set up the suffix area material for the auto generated 
str ing. 

At this point the command has been processed and the 
prefix* auto generated start string* and the suffix have been 
set up. These three regions as a whole* packed together* 
become the "item substitution text"* This text* of course* 
changes each time it is used since it is being incremented for 
each use* 



Now* each time a non-null prefix string is encountered in 
the text data* the prefix string is scanned for the point of 
substitution character (usually w * f ')* and the item 
substitution text is used to replace the point of substitution 
character* At this point* the text data orefix string has 
been constructed* and it is now treated according to the 
settings of the parameters I* S* G and H* whether set 
specifically or by the item command* 

So* it is possible to specify standard preceding and 
following material for the auto generated string* such as 
parentheses* but still specify special text for a particular 
item that is unique to that item - an "*" for example* for a 
footnote* I*e* 

( a ) • x x x x 
♦(b)* yyy 
(c)* zzzz 
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4*0 DESCRIPTION OF MODES 
4.5 ITEM HODE 



TO DO: 1. A. (a) 1 • A. 

2. 8. lb) If. *B. 



ISSUE 



3. C. <c) Hi. C. 

item.n. item»L. item.l*(*) item.r. item.L 

A A A A AA AA AA 



. ^ A 



The ***** is used to represent a blank character* 



4.6 JMi£J!13££ 

\TA8LExtt,tt....tt \TA3LEU0»20. 30... 

As the name implies. TABLE mode is for use in constructing 
tables or columns of tabbed information. 

Unless redefined, the tab character x is ***** and the tabs 
are set to 10. 20. 30. 40. etc* If the tab character is not 
to be redefined, leave the position inmedi atef y after the mode 
name blank. The tabs are relative to the margin so that a tab 
set to 1 places text in the position right after the left 
margin. 

Whenever a data line begins with a blank character* a new 
line is forced and the tabbing po inter I s reset to tab number 
1. (Data for a single line in a table nay be Input on several 
lines.) There are a maximum of 15 tabbing positions 

aval lab) e. 

An all blank line produces a blank line on output. 

PARA and JUST are not applicable to this mode. 

See the SETHx command if a *hard blank" (i.e. 
non-compressible) blank character *ould help In formatting the 
tab! e. 

Examples (\SETU specified at start of document.) 
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4.0 DESCRIPTION OF MOOES 
4.6 TABLE MODE 



1 
2 
3 
4 
5 + 



IBB 

3 
3 
2 
1 




Sao 

l 

2 

3 
4 
5 + 



2 
1 
1 
1 
2 



U'DI!'. fl + S+G) 

6 
6 
6 
6 
7 + 



Inputs 

\keep7 

\table57, 17,26, 35,44 
I'SIZE* ;~Inn" 5~Snn' 

\table58, 13, 27,36,45 



Gnn 1 



Hnr>* (I+S+G> 



51 53 


51 52 , 


16 


52 53 


5 2 51 


}6 


53 52 


53 51 1 


I 6 


5 4 51 


54 51 3 


16 


55 + 50 


55+52 3 


17+ 


\bl ock 
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5.0 MODE NESTING COMMANDS 



5.0 MQ££.ti££IIMiL.£i2!iMM0£ 



This section describes the mode nesting facility of 
TXTCODE. 

for example* 

X+ITEM 
1. Level one in the nest. 

\+ITEtf*IO 
(a) Level two in the nest. 

\- 

2* Level one in the nest again. 
\- 



The above example looks like this when formatted* 

1. Level one in the nest. 

{a) Level two in the nest. 

2. Level one in the nest again. 

Mode nesting is a facility which allows an active mode to 
be temporarily interrupted so that another style of text may 
be processed* before returning to the interrupted mode and 
carrying on as though it had not been disturbed. The second 
mode can also be interrupted itself and so on. In addition* 
there is normally an automatic margin shift which causes the 
interrupting mode to be indented under the Interrupted mode so 
that it aligns with the visual margin of the interrupted mode. 

This provides a simple and powerful way of formatting 
complex text structures. 



Nesting is entered by the first occurrence of w \+mode w and* 
until the next "Xmode" command* which signals the exit* mode 
commands of the form w \ + ... w * H \*... M %r\d W \-... M control 
movement within the nest. Exit is also accomplished when a 
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\EXITNEST command is given or when a "X-mode" command causes 
the nest to decrease to the zero level. ("V-" may also do 
this .) 

The nest has a maximum number' of active 'parentheses 1 of 

10* Nesting beyond this maximum level Is processed using the 

ASIS mode. Dropping back below the upoer limit causes the 
specified modes at each level to resume. 

The mode to use for processing data at each level in the 
nest is set by the mode given on the mode command that most 
recently set a mode for that level. Each of w \+iode M » 
"\*mode w and **\-mode w set the mode at the level that they are 
causing a shift to in the nest. It is possible to move to a 
new level in the nest without specifying a mode* by giving 
w \+ w , »\*»» or *»\- M with no mode. In this case*: the mode most 
recently given for that level is used. Any level which never 
had an initial mode specified* uses the ASIS mode as a 
default. 

Multiple levels may be shifted* if desired* by giving 
"V-n-...* 1 or w \— ... w with or without a node name. 

Moving to a lower level in the nest does not wipe out the 
modes specified for higher nest levels. Even exiting from the 
nest as a whole will not cause the nest mode data to be 
destroyed. It will remain until it is overwritten by a new 
mode at the appropriate level or until a "XCLEARNEST* command 
is given. 

This allows the user to take advantage of repetitive data 
structures to simplify the mode catling orocess and also help 
ensure consistency of formats. Note that for ITEM mode 
especially* even the last used automati cal I y gener ated prefix 
string is remembered and resumed when the correct level is 
again reached. 



Another facility is provided when automatic Indentation is 
on during nesting. This facility is on by default and is 
controlled using VNESTIND Cnest indent Tor \N3^ESTIND at any 
location in the document. With nest indent 01* whenever a 
M \+... M command is found* TXTCODE will cause the new mode to 
be right shifted to the ••visual" margin of the orevious mode. 
Actually* only the FL0WTA8 and ITEM modes have visual margins 
which are usually shifted from the relative margin position. 
(BLOCK mode may also have a shift if the Hnn parameter is 
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used*) It is the relative margin that is being moved to the 
position of the "visual*" margin of the orevious mode. 

When coding back out of the nest* the nest Indent indicator 
is ignored. Shifting back is done if shifting forward was 
done at this level* 



The fol lowing is an example of soue nested modes j* i t h an 
explanation of what is happening: 

\felock 
\+i tea? 
\+FL0WTAB 
\- 
\ + 

\ + 

\*asi s 
\- 
\- 

Inttially* BLOCK mode is active. Then a nest is entered 
with the ITEM mode request. Then soae FLOwTAB material is 
given under several particular items - all with the same 
FL0WTA8 formats. After the last FLOWTA"* section is some ASIS 
text which should have the same margin as the FL0WTA8 mode had 
when it was called. Then ITEM mode is afcked up and finished 
and finally the original mode {block) Is resumed* which was 
active before the nest was entered. 

w \*mode M replaces the current mode at a particular level 
with a new mode* The new mode is not Indented because it is 
at the same level as the one already there* 



It should be noted that when a mode is restored* it is the 
mode that is restored and not all the associated conditions 
that may have been active during that node. 

All such features remain under the users direct control 
alone. For example* if a trigger character for underlining 
had been set but was later cleared* reentering the mode during 
nesting would not reestablish the underlining trigger 
char acter* 
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In addition* margin control is also still under the user's 
direct control* The changes In the relative margin are made 
during the shifting process in going from one mode to another 
In the nest (when nest indent Is active) In or*der to fashion 
the indentation structure* but the user nay give extra margin 
adjustments of his own* He should be careful to move the 
margin back when the structure is completed* and before he 
changes levels preferably* Otherwise* arbitrary margin 
changes will fracture the nest structure as a whole at that 
point* 

The visual margin is defined as the relative margin for 
ASIS* COMMENT and TABLE modes* For FL3HTA3 -node, the visual 
margin is where the flowing text starts* For ITEM or BLOCK 
mode* the visual margin is where the body of the text falls 
when line overflow occurs* (Note that the default visual 
margin for BLOCK mode is the normal margin*) 

&24£.£w.ii£ a iii3 

To go into the nest another level give? 

\+mode 
To change modes at the same level give: 

\*mode 
To drop out of the nest one level give? 

\-mode 

These three commands* containing the w + w * w * w or W - M in 
front of the mode* control the movement within the nest* 
entrance into a nest (first M \+*** H )* and exit from the nest 
(a "\-» at level one). Any mode cowhand without the plus* 
asterisk or dash is a regular non-nest node command and will 
terminate a nest if one is active* 

Each time a deeper mode is entered* the visual margin value 
is saved for the previous mode - that is* the amount to shift 
the relative margin by is saved* if nest Indentation is 
active* Next the relative margin value is adjusted if 
necessary* Then the new mode is set up and the actual mode 
data is processed* 
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The entire mode nest may be cleared by using the XCLEARNE3T 

{when outside a nest) or \EXITN£ST*C commands* This destroys 

all memory of modes which have been defined in the nest 
structure* 

A£II3MSLl£ 

This command causes an immediate exit from any level of a 
nest* The most recent \mode command governs the active mode 
on exit. If the **C H parameter is specified* the whole nest is 
completely cleared of mode information, 

*£UMM££I 

The CLEARNEST command clears all nest levels fce.io.UiJ the 
current level* If nesting is inactive* It clears the whole 
nest - levels 1 to 10; if nesting is active* it clears levels 
n+1 through level 10. The current and lower levels are not 
affected and nesting is not disturbed. 
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6.o fl£xc&i£iiQii-a£-caaiiA&QS 

6.1 MSIMmQM-im-£aHMMH£ 

These commands apply to the title black (top of page title 
information)* folio line (page footing information)* and any 
supplemental lists generated such as a table of contents. 
(See \TA8LC0N command). 

\TITLEn* xxxx. • .x or VTITLE^xxxx. • .x 

The xxxx..*x is the i nformat ion which is to appear in the 
title position n (n»l*2..*6) of subsequent pages. Up to six 
title lines may be in effect. Unused title lines will be 
squeezed out of the title block. The default title line is 
n*l» which appears between the page number and date lines. 
Other title lines follow the date title line. 

\DATE*xxxx.. *x 

The current date (in YY/MM/DQ format) will be replaced by 
xxxx...x at the upper right hand position of subsequent pages. 
It will appear on the current page too* if no text other than 
page header text has been given yet. E.g. \DAT"E*13 JUL 79 

1EULIU 

\FQLIQ*xxxx. ..x 

At the bottom of the page on the folio line* xxxx...x will 
appear right justified on the current and! following pages. 

If a table of contents is desired* this command should be 
issued once at the start of the input file. It should be 
given h&t2L& any section numbers (V n.h...n xxxxx...x) are 
gi ven« 

UUIQS££-aad-lMQAyiai££ 

AUTOS EC turns on automatic section numbering. The level 
number is given by n on a section number" command line. Any 
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6.1 DESIGNATION TEXT COMMANDS 



n.n*#.*n forms have their level calculated from the n*n**.n* 
That is* n*0 is level 1; run is level 2% n.n.n is level 3j 
etc* The first level 1 becomes 1.0? the second level 1 
becomes 2.0 etc.* while the first level 2 becomes 1.1 and so 
on. 

Automatic section causes page numbers to change to the n-n 
format? it also causes a section header box to appear at the 
top of each page. See Section Numbers for additional detail* 



6.2 taax-mi-£QMAtii& 



These commands control the text which Is in the middle of 
the page - between the title block information and the folio 
I ine* 



6.2*1 SECTION NUMBERS 



X n.n..*n xxxxx*.*x or \ n xxx...x or \ xxx«..x 

This command establishes a section number and title data in 
the text and in the table of contents.' (See the \TABLC0N 
command for generating a table of contents). > Normally the 
first format is used with XNOAUTOSEC and the second form with 
XAUTOSEC. However* the first format can be used by XAUTOSEC 
and the second format will produce titles with no section 
numbers if used with \N0AUT0SEC. 

Paging (n.O levels)* spacing* underlining* and 
capitalization are produced automat leal I y and are governed by 
the level being processed. Standard TXTFORM format for 
section numbering is used. See the Heading Level Selection 
Tab! e* 

Note? the space after the back slant (XI and also after the 
section number* One space Is sufficient* 

In the second form* n is a level number from 1 to 7* or 11 
to 17. (See XAUTOSEC) 
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In the third form* no section number apoears and the text 
is underlined* It is equivalent to \ 14 xxx*«*te*« (Notes the 
third format should not be used if the first word contains any 
periods w . fl j use format 2 with n*14. The same applies if the 
first part of the title text is numeric.) 

NBs Individual section number lines which are too long may be 
omitted from a table of contents by TXTFORH. 
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6»0 DESCRIPTION OF COMMANDS 
6*2.1 SECTION NUMBERS 



ti£AfiUJ&-L£g£L-&£U£IXfl£LIA&L£ 



+— — ~ — «. — -_ _+ — .+- . — + + „—_„+—. 

3 3 3 3 LINES 3 LIHES 3 

J 3 NEW 3 ALL 3 SPACEO? SPACEE53 UNDER 

J J PAGE 3 CAPS 3 BEFORE? A*=TER ? LINED 

+ . + ; — + + * + — . 

3H1CH11) SECTION 3 3 3 3 3 

IX 1 xxx..,x ! I 3 3 ? 

!\ 11 nx,.ix * 3 ! * ? 

!\ n.O xh.mX J ? ? 1 ? 

3 LEVEL 1 3X3X3 3 5 ? X 

+ _+ — . + — + — - — .— +„ . — + — * 

3H2*H12) SECTION 3 3!?? 

t\ 2 xxx«iiS( « « « » » 

!\ 12 xxx,..x 3 3 3 * * 

!\n.nxxx...x 3 3 3 * * 

J LEVEL 2 * 3 3 * 3 

3 XHEADA 3 3 X 3 2 3 1 ? X 

J \HEADB J 3 X 3 3 ? 2 ? X 

J \HEADC J 3 X 3 2 3 1 3 X 

3H3<H13) SECTION 3 3 3 3 3 

!\ 3 xxx...x 3 • 3 * 3 

!\ 13 xxx,,,x 3 3 3 3 1 

3X n«n«n xxx...x 3 3 3 3! 

J LEVEL 3 3 3 3 3 3 

J XHEADA 3 3X3231? 

3 XHEADB 3 3 X 3 3 3 2 3 

J VHEADC 3 3X32? 1 ? 

+ _+ + f , — -+ — -+ 

3H4CH14) SECTION 3 3 3 3? 

3X4xxx*.*x 3 3 3 3 3 

JX 14 xxx •♦•x 3 3 3 ? ? 

!\ n.n.n.n xxx...x 3 3 ? 3 

1 \ xxx« t * x * < * • • 

J LEVEL 4 3 3 3 3! 

J XHEADA 3 3 3 1 3 1 ! X 

3 \HEAD8 J 3 J 3 ? 2 3 X 

3 XHEADC 3 3 3 2 3 I 3 X 
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+........., — — - — +. ..+.... . +... - 4. ....,...+ ...... 

3 3 3 3 LINES I LIMES 3 

J ! NEU i ALL 3 SPACED? SPACED! UNDER 

3 J PAGE 5 CAPS 3 BEFORE! AFTER ! LINED 

+- — — ■ -.————+-— — ...+— ..-..+...-....4....— ....+ -. — — 

!H5(H15) SECTION J 3 3 ? 1 

!\ 5 xxx,..x 5 1 J ; ; 

3\15xxx...x 3 1 I ! ! 

i\n.n.n.n.nxxx...x ! J 1 ? 

3 LEVEL 5 J 3 5 3 3 

3 XHEADA J 5X11! 3 

3 \HEAOB 3 i X I 1 5 3 X 

J \HEADC 3 1X51! ! X 

4. «. 4. +.. *. 4. —4. 

3H6CH16) SECTION ! 3 3 3 3 

t \ 6 x x x » * * x • * • « * 

S\ 16 xxx.*.x 3 ! ! ! 3 

JV n.n.n.n.n.n xxx...x 3 3 ! 3 

3 LEVEL 6 3 3 3 3! 

3 \HEADA 3 3 J 1 3 3 X 

3 \HEADB 3 3 3 3 3 X 

3 XHEADC 3 3 X 3 3 3 

4.-. , . .— . 4— ..... - + ....... + .4. .4....... 

3H7CH17) SECTION J 3 J 3 3 

i\7xxx...x t * * 1 « 

« \ 1 7 x x x **. x * « 1 1 § 

3\n*n.n.n.n.n.nxxx...x3 3 * 1 

J LEVEL 7XHEADC J J 3 1 3 3 X 



4.. ......+ — ... — + 4. 4. 



+ + 



If AUTOSEC is off (default)* the first form shown 
(\ n xxx«.) is converted to the second form shown 
C\ In xxx..) and treated accordingly. 

If AUTOSEC Is on* CVAUTGSEC i ssuedli " age numbering changes 
from the simple sequential format to the n-n format. Also» a 
4 line header box will be produced on each page which will 
contain the currently active major section (n.O level) and the 
currently active heading level being processed* of whatever 
level. AUTOSEC doesn't produce numbering for <\ In xxx..) 
type headers* but it does replace any n»n*» : «:h forms* which 
effectively allows renumbering of old section numbers. 



NOTE: that 
header command 



AUTOSEC effects do not occur unt i 1 the first 
line (\ n xxx«..x) has been encountered. 



Also note that the form (\ 
following form in all cases: <\ 



xxx.. «x) is 
14 xxx.. .x) • 



treated as the 
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6.0 DESCRIPTION OF COMMANDS 

6.2.2 FEATURE SELECTION/DE-SELECTION 

6.2.2 FEATURE SELECTION/DE-SELECTION 

1EA££ 

\PARA \PARAnn NNOPARA 

With the PARAgraph feature selected* BLOCK mode paragraphs 
which begin at the left margin have th»lr first line indented 
by the number of spaces specified for the \PARAnn command or 
by three spaces for the \PARA command. 

!UliJ2£fi-iQJl.lt.QllllJ2£& 

Specifying UNDERlining will cause the following lines of 
text to be underlined until a N0UNDER1 f ne command is given or 
until the mode is changed or a section number is encountered. 
This command is oriented toward underlining for which it is 
not convenient to use a trigger character for control. (See 
the SETUx command). 

Right JUSTi f ication occurs as a default. Text which is 
being built up so that it overflows to the next line when the 
right margin is met is normal 1 y al i gned with the right margin 
by adding extra spaces between words. This feature has no 
effect* even if selected* if it is not appropriate to the 
currently active mode. TABLE and ASIS mode ignore this 
feature. Note that JUSTi fi cat ion only allows backing up in 
the line for 30 characters. Therefore,. If a blank* -» or / is 
not found* a 'LINE OVERFLOW 1 message will be Issued since a 
place could not be found to break f or J JST1 f 1 cat 1 on. 

lMU.£.aaji_lK0&Qi{2 

The BOLDface command instructs the formatter 4 to print each 
character which follows in such a way that the characters 
appear darker and thicker. BOLDfacing stops when the 
NQBOLDfacing command is given or when the moie is changed or 
when a section number is encountered. The command is oriented 
towards BOLDfacing text for which a trigger character in the 
text itself is not appropriate* (See the SETBx command). 

If it is desired to have each output line in the document 46 

followed by the number of the line* issuing the SEQ command 47 

will initiate this process. (Default Is NOSEQuencing) . 48 

SEQuencing numbers will appear right justified on the fifth 49 
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6.0 DESCRIPTION OF CQHMANDS 

6.2.2 FEATURE SELECTION/OE-SELECTIQN 

character position to the right of the right margin or the 1 
length as established by the TXTFQRH "F-IRHAT" command (default 2 
is 75)* whichever is greater - absolute soluun 80 by default. 3 
SEQuence numbers start at 1 on each new Page and appear only 4 
beside text in the body of the document* The feature may be 5 
turned on or off at any point in the document. 6 

7 

NOTE? The TXTFORH FORMAT command is used to give the margin 8 
values for heading and folio lines and to specify the total 9 
page depth. It may only be given once and must be before any 10 
text is input* Using the direct TXTFORH command capability* 11 
it may be specified as follows* 12 

13 

WFQRMATaa.bb.nn 14 

15 
where aa is the left margin (default is 7)* bb is the absolute 16 

line length (default is 751* and nn is the total page depth 17 

(default is 60). These margin values do not a poly to the main 18 

body of the text. 

Sometimes material on different lines must be kept on the 
same page to be readable* To make sure that the next nn lines 
of output appear on the same page specify K?€Pnn* NOKEEP 
serves only to mark the end of the kept text and is not 
actually necessary. 

lSIM£i£-Jfl^lHQUfiLI 

It is often desirable to allow different standard line 
spacing on documents. For example* double spacing is quite 
useful for draft documents to which many changes are usually 
made. SINGLE and DOUBLE select single and double spacing 
respectively for the formatted output text. 

Att£A£Ai._ltt£A&£i.-£a4.1id£AiK 

These commands allow selection of the TXTFORM heading 
styles A* B* and C respectively. See the heading level 
selection table for a description of the effect of the 
different heading styles. 

1£Q2££ 

This is used to produce a TXTFORM command statistics and 
error summary list at the end of the formatted document* 
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6.2.2 FEATURE SELECTION/DE-SELECTION 

The HARK command is used to set a margin note in the line 
being formatted. An asterisk <*) Is inserted at the current 
position in the line and a pointer CO is placed in the right 
margin. 



6.2.3 TEXT FORMAT CONTROL COMMANDS 

lME£lti 

\MARGINnn ANARGIN \MARGIN+nn \MARGIN-nn 

This command determines where text should normally start at 
the left hand side of the page. MARGIN^ redefines the BASE 
MARGIN (default is 10) to the net* value nn. Normally 
adjustments are made to the margin by specifying the change 
relative to the old margin instead of soeclfylng the absolute 
margin each time. The *nn and -nn foru is used to accomplish 
this. Note that a XMARGIN+2 followed by \^ARGI^+3 command is 
equivalent to a VMARGIN+5 command. 

At any time, the BASE MARGIN* the one defined by the last 
MARGINnn command* or MARGIN10 by default* may be returned to 
by asking for MARGIN with no value. In this way the margin 
may be temporarily redefined and then returned to the old 
value without remembering that value. 

The ABSOLUTE margin Is the extreme lefthand side of the 
pagej the BASE margin is at 10 unless redefined using 
\MARGINnn; and the RELATIVE margin is i nf ti al I y equal to the 
BASE margin. The RELATIVE margin is aoved by \MARGIN+nn and 
\MARGIN-nn commands as well as by mode nesting commands and 
may be reset to the BASE margin by \MARSIN. 

ILZMlti 

UENGTHnn UENGTH \LENGTH+nn \LENGTH-nn 

This command specifies the LENGTH of the text line as 

measured from the BASE MARGIN {see above). ThQ default value 

is 62. Hence. an ASIS line of up to 62 characters can be 

placed on each output line using the default value. 

(\MARGIN-nn and VMARGIN+nn will lengthen or shorten the 
effective line length.) Adjustments may be lade relative to 

the old length in a similar manner to the MARGIN command 
above. 
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6,0 DESCRIPTION OF COHHANDS 

6.2.3 TEXT FQRHAT CONTROL COMMANDS 

VSKIPnn 

To write nn blank lines to output at any time* use the 
SKIPnn command. The nn defaults to I. Note that if paging 
occurs in the process* the command does not leave the rest of 
the blank lines at the top of the next page. If an actual 
amount of blank paper is desired* say 2 Inches* issue a KEEP12 
(2 inches times 6 lines per inch « 12 lines) then a SKIP12. 

\PAGE or \PAGEnnn 

At any time* a PAGE eject may be forced using this command. 
Two consecutive page ejects do not* however* leave a blank 
page. (Entering the command BLANK between the two PAGE ejects 
will). If it is desired to cause the next PAGE number to be 
reset to a value nnn* include the value immediately after the 
command. 

\BLANK or \8LANKnn 

If this command is given* nnn blanks (default is 1) will be 

inserted in the text stream at the current position. See the 

SETHx command for generating "hard blanks" using a specially 

designated character instead of the 8LAMK command. 

1££M££ 

VCENTER*xxxx.. .x or \CENTER*3* !J*xxx.. . x 

The xxxx.*.x text will be CENTERed on a new line between 
the left and right margins. Consecutive embedded blanks are 
compressed to one blank. 8 and J parameters are for 
boldfacing and underlining xxx...x. Soecial trigger 
characters in the xxxx...x text will be recognized and 
processed* if set* if the first form of the command is used. 
See the SETU* SETS and SETH commands. 
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6.0 DESCRIPTION OF COMMANDS 
6.2.4 APPENDICES 

6.2.4 APPENDICES 

li£IA££ 
\SETAPP«a-xxx. ..x 

This command is used to define sipoandix text. The 
character value of "a" defines the appendix identifier and 
* # xxx..»x M is the appendix title. This information appears in 
the table of contents {see the TABLCCH command! and the user 
should set up his own appendix title pais as desired as well 
as the body of the appendix text. 

The appendix identifier **a w precedes both the section 
number and the page number wherever they apoear. One method 
of setting up an appendix follows: 

VSETSEC1 - resets section numbers to 1 

VSETAPP»A-APPENDIX A - sets appendix character and title 

\PAGE1 - sets up title page ns page 1 

\BLANK 

\SKIP20 

\CENT£R»B»* Appendix A * 

\CENTER=Special Conditions 

\PAGE - starts body of appendix text 

\ 1 Introduction 



6.2.5 80X GENERATION COMNANDS 

The following commands are used to draw boxes but the 
vertical spacing in boxes is controlled by commands or text 
given while a box is active. Usually TABLE or FL0WTA8 mode is 
used to supply the text for a box. 

\B0X or YBOX*i>lnn.A*nn»B> £-lnn# R# Olnn 

The BOX command is used to Initiate the drawing of vertical 

60460280 01 



CDC - SOFTWARE ENGINEERING SERVICES 
TXTCOOE 2.0 Reference Hanual 



6-11 

13 DEC 83 
REVS 1 



6*0 DESCRIPTION OF COWHANDS 
6.2,5 BOX GENERATION COMMANDS 



lines which are all joined together by a horizontal line at 
the top. For example* the command \8QX» 10*29* 3D would be used 
to start the following box? 



— ♦ 



>-•*■ 



The two outside columns are at columns 10 and 30 with 
respect to the relative margin* while the center line 
{vertically) is at column 20* By defaults the column 
positions are with respect to the relative margin. At any 
point in the command* the reference point may be changed to 
the 8ASE margin with the *B W parameter* to the ABSOLUTE margin 
using W A W * or back to the RELATIVE 
parameter* I See the MARGIN command 
margins*) The A* 8* and R parameters 
times In the command if desired* 



iar gi n 

for an 
nay be 



with the W R" 

explanation of 

used several 



For the BASE and RELATIVE margins* it 
specify a column position to the left of 

preceding the column number with a minus sign . ...,.,,..*.«, 
**~1 M and *"1** specify vertical lines which are adjacent to each 
other surrounding the margin {"0" is equivalent to w -l w ). 



is possible to 
the margin by 
"-*•- Therefore 



Up to 17 vertical lines may be in effect at once* 

If \B0X is given with no parameters* the settings in effect 
for the previous box are used* 

IttOllfiQ..' 

\M0DB0X* C-lnn* A*nn*8*C-lnn.R. t-3nn 

This command is used to modify a box in progress. The 
parameters are the same as for the BOX command* For each 
column given* there are two possible actions* If that column 
already has a vertical line being drawn* the line is turned 
off* If it does not have a vertical line in effect* one is 
started* In addition* MOOBOX joins the resulting outside 
verticals with a horizontal line. The above box had its 
center vertical terminated by the following commands 

\MQD80X*20 
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l£Q£iIta£ 

This command draws a horizontal line between the inside and 
outside vertical lines of the box* The third horizontal in 
the box above was drawn this way. 

IttOfifl* 

NGBQX is used to end a box currently in affect* drawing the 
final horizontal line terminating the box. 

Exampl e: 

5 A J ABSOLUTE J This parameter causes the following } 
I 5 ? values to refer to the ABSOLUTE J 

* ' I margin* I 

* — + — _ . — •+„ — -. — ™ — •, «. — «„«._, — .4, 

* B * BASE * This par ameter causes the following * 
« * » values to refer to the BASE margin. I 

+—.<--<_-+——-- ..-.—.—— +_-..«- _—™„ _„„ —«„-.— — ™— —_+ 

5 R J RELATIVE I Finally, this parameter' causes the * 
J * J following values to refer to the S 

5 I S RELATIVE margin. J 

+. -4 -™- — -+ ... «, — • — „„ — — — , — -+ 



Input: 

\KEEP12 

\B0X.-1«7>21#62 
\F10WTA8 1 3*10*24 
VLENGTH-3 

5 A ^ABSOLUTE ;This parameter causes the following values to 
refer to the ABSOLUTE margin. 
\80XLINE 

;B JBASE jThis parameter causes the following values to 
refer to the BASE margin. 
\B0XLINE 

JR ^RELATIVE ;Finally» this parameter causes the following 
values to refer to the RELATIVE margin. 
VNQBOX 
\LENGTH 
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6.0 DESCRIPTION OF COMHANDS 
6.2.6 ESCAPE CHARACTER DEFINITION 



6.2.6 ESCAPE CHARACTER DEFINITION 

To reSET the master Escape character for commands to 
another character x issue this command. (Default is \) 



on a trigger character x to control the starting 
of Underlining give this command* The feature is 
by giving a blank character for the x. (Default 
no trigger character set). Also* note that the 
mode change or the occurrence of a section number 
turn off Underlining just as the second 



To turn 
and stopping 
turned off 
condition is 
effect of a 
command will 

occurrence of the trigger character would. But the feature 
itself remains set. A suggested character to use for 
triggering underlining is . or ~» 

NOTE: If the underlining and boldfacing trigger characters 
are set to the same character at the sane tine* both functions 
will be controlled by the one trigger character. 

This feature is exactly analogous to underlining (see 
above) except that it controls Boldfacing. A suggested 
character to use to trigger this feature on nnd off is 3. 

From time to time it is necessary to use special blanks in 
the text called **hard blanks*** which will not be compacted 
into one (1) blank or expanded into more than one blank. The 
hard blank is also useful in forcing tabbed data into proper 
alignment if the left hand side is not straight. The BLANK 
command is not always convenient in such cases. This command* 
SETHx* allows the user to specify a character which is to be 
considered to be a hard blank until the feature Is turned off. 
Each subsequent occurrence of the character forces a single 
blank to be shown in Its place. 



A suggested character 
left apostrophe. 



to use is the circumflex- ( A ) or the 
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7.0 fiI£I£I_mffl£B_amiUM£S 

Any TXTFORH command way be given directly by prefixing that 
command by two master Escape characters rather than one. The 
preprocessor strips off the first master Escape character and 
passes the command directly to TXTFOR1* Hn command validity 
checking is performed. 

e.g. \\V10>20*30 

* * * 
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